* {
	margin: 0;
	padding: 0;
}

html,
body {
	height: 100%;
	width: 100%;
	background-color: #000;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.container {
	width: 120px;
	height: 60px;
	border-radius: 60px;
	overflow: hidden;
	display: flex;
	flex-direction: row;
	align-items: center;
	transition: all 0.3s ease-in-out;
}

.container:hover {
	width: 400px;
}
.container:hover .input-text {
	flex: 1;
}

.input-text {
	width: 0;
	height: 100%;
	background-color: #fff;
	opacity: 0.4;
	border: none;
	border-radius: 30px 0 0 30px;
	transition: all 0.3s ease-in-out;
	outline: none;
	text-indent: 1em;
}

.input-btn {
	width: 120px;
	height: 100%;
	background-color: #f00056;
	border: none;
	border-radius: 0 30px 30px 0;
	outline: none;
	text-align: center;
	line-height: 60px;
	font-size: 18px;
	color: #fff;
}
